## Instituto Tecnológico de Costa Rica Área Académica de Ingeniería en Computadores (Computer Engineering Academic Area)

Programa de Licenciatura en Ingeniería en Computadores (Licentiate Degree Program in Computer Engineering)

Curso: CE-4301 Arquitectura de Computadores I (Course: CE-4301 Computer Architecture I)



Documento de Descripción del ISA (First Project)

Realizado por:

Made by:

Fabián Astorga Cerdas 2014040808 Javier Sancho Marín 2014159997 Óscar Ulate Alpízar 201229559

Profesor:

(Professor)

Fabián Zamora Ramírez

Fecha: Cartago, 17 octubre, 2017

(Date: Cartago, October 17, 2017)

# 1.ASPECTOS GENERALES

| Elementos del ISA          | JOF32                                                                                                                                                                                                                                                                 |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Clase de ISA               | <ul><li>RISC</li><li>Load/Store</li></ul>                                                                                                                                                                                                                             |
| Registros                  | <ul> <li>El procesador cuenta con 16 registros de 32 bits en<br/>total de los cuales: 14 son de uso general, 1 registro<br/>para almacenar el número cero, 1 registro para la<br/>bandera de salto</li> </ul>                                                         |
| Tipos de datos             | <ul><li>Bytes de 8 bits</li><li>Palabras de 4 bytes</li></ul>                                                                                                                                                                                                         |
| Modos de direccionamiento  | <ul> <li>Inmediato con desplazamiento [Rn, #±imm]</li> <li>Registro [Rn]</li> <li>Registro escalado con desplazamiento [Rn, ±Rm, shift]</li> </ul>                                                                                                                    |
| Organización de<br>memoria | <ul> <li>Soporta Big-Endian.</li> <li>Espacio de direccionamiento: 2MB</li> <li>Addressability: 32 bits.</li> <li>Todos los accesos a memoria deben estar alineados.</li> <li>Los accesos a memoria pueden ser a nivel de byte y palabra.</li> </ul>                  |
| Formatos de instrucción    | <ul> <li>Data processing immediate shift</li> <li>Data processing register shift</li> <li>Data processing immediate</li> <li>Load/Store Immediate offset</li> <li>Load/Store register offset</li> <li>Load/Store multiple</li> <li>Branch/Branch with link</li> </ul> |

| Operaciones  | <ul> <li>Load/Store.</li> <li>Operaciones de ALU (lógicas y aritméticas).</li> <li>Branches.</li> <li>Saltos.</li> </ul> |
|--------------|--------------------------------------------------------------------------------------------------------------------------|
| Codificación | <ul> <li>Instrucciones de tamaño fijo: 32 bits</li> <li>El modo de direccionamiento se guarda en el opcode</li> </ul>    |

# 2.NOTACIÓN

Tabla 2A. Convención notacional

| NOTACIÓN | SIGNIFICADO                                                                                                                                                                                                                                                                  |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BaseR    | Registro base. Utilizado para dar referencia a un registro que se esté utilizado para llevar a cabo alguna operación. (R <u>0,</u> ,R15)                                                                                                                                     |
| A[i:d]   | Utilizado para delimitar una sección específica de un dato compuesto por un conjunto de bits. Por ejemplo: el código de operación (opcode) puede ser interpretado como la sección del dato que está entre el bit 31 (i) y el bit 26 (d), por lo tanto: opcode = instr[31:26] |
| #Numero  | Número en notación decimal.                                                                                                                                                                                                                                                  |
| *        | Operador utilizado para interpretar una multiplicación.                                                                                                                                                                                                                      |
| ::       | Operador utilizado para concatenar dos conjuntos compuestos por uno o más bits.                                                                                                                                                                                              |
| Offset   | Dato compuesto por 19 bits con el objetivo de<br>realizar una operación específica dentro de las<br>instrucciones de formato I. (Véase la sección<br>4)                                                                                                                      |
| PC       | Contador de programa. Compuesto por 10 bits, el cual contiene una dirección de memoria de la siguiente instrucción que se debería ejecutar.                                                                                                                                  |

# 3.FORMATO DE INSTRUCCIONES

a. Tipo R

|    | OPCODE | RS |       | RT | RD |    |    | SHAMT | FUNCTION |   |
|----|--------|----|-------|----|----|----|----|-------|----------|---|
| 31 | 27     | 26 | 23 22 | 19 | 18 | 15 | 14 | 10    | 9        | 0 |

## b. Tipo I

|    | OPCODE |    | RS |    | RT |    | INMEDIATO |
|----|--------|----|----|----|----|----|-----------|
| 31 | 27     | 26 | 23 | 22 | 19 | 18 | 0         |

## c. Tipo J



## **4.SET DE INSTRUCCIONES**

**ADD** Suma

#### FORMATO ENSAMBLADOR

ADD RD, RS, RT

### **CODIFICACIÓN**

| 00000 |    |    | RS |    |    | RT |    |    | RD |    |    | 00000 |    |   | 000 | 000000 | 0 |   |
|-------|----|----|----|----|----|----|----|----|----|----|----|-------|----|---|-----|--------|---|---|
| 31    | 27 | 26 |    | 23 | 22 |    | 19 | 18 |    | 15 | 14 |       | 10 | 9 |     |        |   | 0 |

## **OPERACIÓN**

if (bit[31:27] == 00000)RD = RS+RT

### **DESCRIPCIÓN**

En caso de que el código de operación de la instrucción sea el establecido para la suma, se almacena el resultado de dicha suma de los registros RS y RT en el registro RD.

#### **EJEMPLO**

ADD R5, R7, R9 : R5 = R7+R9ADD R2, R2, R4 : R2 = R2+R4 **SUB** Resta

#### FORMATO ENSAMBLADOR

SUB RD, RS, RT

## **CODIFICACIÓN**



## **OPERACIÓN**

if (bit[31:27] == 00001)

RD = RS-RT

### **DESCRIPCIÓN**

En caso de que el código de operación de la instrucción sea el establecido para la resta, se almacena el resultado de dicha resta entre los registros RS y RT en el registro RD.

#### **EJEMPLO**

SUB R5, R7, R9 : R5 = R7-R9

SUB R2, R2, R4 : R2 = R2-R4

## **AND**

## And lógico

#### FORMATO ENSAMBLADOR

AND RD, RS, RT

### **CODIFICACIÓN**

| 00010 |    |    | RS |    |    | RT |    |    | RD |    |    | 00000 |    |   | 000000000 |   |
|-------|----|----|----|----|----|----|----|----|----|----|----|-------|----|---|-----------|---|
| 31    | 27 | 26 |    | 23 | 22 |    | 19 | 18 |    | 15 | 14 |       | 10 | 9 |           | 0 |

## **OPERACIÓN**

if (bit[31:27] == 00010) RD = RS & RT

## **DESCRIPCIÓN**

En caso de que el código de operación indique un and, Aplica este operador lógico entre los registros RS y RT y guarda el resultado en el registro RD.

### **EJEMPLO**

AND R5, R7, R9 : R5 = R7&R9

AND R2, R2, R4 : R2 = R2&R4

OR Or lógico

#### FORMATO ENSAMBLADOR

OR RD, RS, RT

### **CODIFICACIÓN**

| 00011 | R     | ß | Ò  | RT |    | RD |    | 00000 |   | 000000000 |   |
|-------|-------|---|----|----|----|----|----|-------|---|-----------|---|
| 31    | 27 26 |   | 22 | 19 | 18 | 15 | 14 | 10    | 9 |           | 0 |

### **OPERACIÓN**

if (bit[31:27] == 00011)  

$$RD = RS \mid RT$$

## **DESCRIPCIÓN**

En caso de que el código de operación indique un or, aplica este operador lógico entre los registros RS y RT y almacena el resultado en el registro RD.

#### **EJEMPLO**

OR R5, R7, R9 : R5 = R7|R9OR R2, R2, R4 : R2 = R2|R4 NOR Nor lógico

#### FORMATO ENSAMBLADOR

NOR RD, RS, RT

## **CODIFICACIÓN**



### **OPERACIÓN**

if (bit[31:27] == 00100)

RD = RS NOR RT

### **DESCRIPCIÓN**

En caso de que el código de operación indique un nor, aplica este operador lógico entre los registros RS y RT y almacena el resultado en el registro RD.

### **EJEMPLO**

NOR R5, R7, R9 : R5 = R7 NOR R9

NOR R2, R2, R4 : R2 = R2 NOR R4

## SLL Desplazamiento lógico a la izquierda

#### FORMATO ENSAMBLADOR

SLL RD, RT, #SHAMT

#### CODIFICACIÓN



### **OPERACIÓN**

if 
$$(bit[31:27] == 00101)$$
  
RD = RT << SHAMT

### **DESCRIPCIÓN**

En caso de que el código de operación indique un SLL, aplica un desplazamiento a la izquierda del número guardado en el registro RT la cantidad de veces que lo indique el valor del *shift amount* (SHAMT) y guarda el resultado en el registro RD.

#### **EJEMPLO**

SLL R5, R7, #2 : R5 = R7 << 2 SLL R2, R2, #4 : R2 = R2 << 4

#### **NOTA**

Nótese que el registro RS no se utiliza en esta operación.

## SRL Desplazamiento lógico a la derecha

#### FORMATO ENSAMBLADOR

SRL RD, RT, #SHAMT

## **CODIFICACIÓN**

| 00110 |    |    | 0000 |    | RT |    | RD |    | SHAMT | 000000000 |  |
|-------|----|----|------|----|----|----|----|----|-------|-----------|--|
| 31    | 27 | 26 | 23   | 22 | 19 | 18 | 15 | 14 | 10    | 9         |  |

### **OPERACIÓN**

if (bit[31:27] == 00110)RD = RT >> SHAMT

### DESCRIPCIÓN

En caso de que el código de operación indique un SRL, aplica un desplazamiento a la derecha del número guardado en el registro RT la cantidad de veces que lo indique el valor del *shift amount* (SHAMT) y guarda el resultado en el registro RD.

#### **EJEMPLO**

SLL R5, R7, #2 : R5 = R7 >> 2 SLL R2, R2, #4 : R2 = R2 >> 4

#### **NOTA**

Nótese que el registro RS no se utiliza en esta operación.

## **MULT**

## Multiplicación

#### FORMATO ENSAMBLADOR

MULT RD, RS, RT

### **CODIFICACIÓN**



### **OPERACIÓN**

if 
$$(bit[31:27] == 00111)$$
  
RD = RS \* RT

#### DESCRIPCIÓN

En caso de que el código de operación de la instrucción sea el establecido para la multiplicación, se almacena el resultado de dicha operación entre los registros RS y RT en el registro RD.

#### **EJEMPLO**

MULT R5, R7, R9 : R5 = R7\*R9MULT R2, R2, R4 : R2 = R2\*R4

#### **NOTA**

Se utiliza el símbolo '\*' para denotar la multiplicación entre dos registros.

**DIV División** 

#### FORMATO ENSAMBLADOR

DIV RD, RS, RT

### **CODIFICACIÓN**



#### **OPERACIÓN**

if 
$$(bit[31:27] == 01000)$$
  
RD = RS / RT

#### DESCRIPCIÓN

En caso de que el código de operación de la instrucción sea el establecido para la división, divide el valor del registro RS entre el valor del registro RT y almacena el resultado en el registro RD.

#### **EJEMPLO**

DIV R5, R7, R9 : R5 = R7/R9DIV R2, R2, R4 : R2 = R2/R4

#### **NOTA**

Se utiliza el símbolo '/' para denotar la división entre dos registros.

**ADDI** 

Suma inmediata

#### FORMATO ENSAMBLADOR

ADDI RT, RS, #INMEDIATO

## **CODIFICACIÓN**

| 01111 |      | RS    | RT        | INMEDIATO |
|-------|------|-------|-----------|-----------|
| 31    | 27 2 | 26 23 | 3 22 19 1 | 8         |

## **OPERACIÓN**

if (bit[31:27] == 01111)

RT = RS + INMEDIATO

### **DESCRIPCIÓN**

En caso de que el código de operación de la instrucción sea el establecido para la suma inmediata, se almacena el resultado de dicha suma del registro RS y el número inmediato en el registro RT.

#### **EJEMPLO**

ADDI R5, R7, 9 : R5 = R7 + 9

ADDI R2, R2, 4 : R2 = R2+4

## **BEQ**

## Branch on equal

#### FORMATO ENSAMBLADOR

BEQ RS, RT, offset

## **CODIFICACIÓN**

| 01001 |    | RS | 3  | RT |       | OFFSET |  |
|-------|----|----|----|----|-------|--------|--|
| 31    | 27 | 26 | 23 | 22 | 19 18 |        |  |

### **OPERACIÓN**

## **DESCRIPCIÓN**

Si el código de operación de la instrucción es el establecido para el BEQ, compara los registros RS y RT. En caso de que los registros contengan el mismo valor, el PC toma el valor inmediato (offset) de la instrucción y ejecuta la instrucción que allí se encuentra.

#### **EJEMPLO**

BEQ R2, R3, 100: Si R2=R3, PC = 100

BEQ R5, R7, 64 : Si R5=R7, PC = 64

### **BNE**

## Branch not equal

#### FORMATO ENSAMBLADOR

BNE RS, RT, offset

### **CODIFICACIÓN**



### **OPERACIÓN**

## DESCRIPCIÓN

Si el código de operación de la instrucción es el establecido para el BEQ, compara los registros RS y RT. En caso de que los registros contengan valores diferentes, el PC toma el valor inmediato (offset) de la instrucción y ejecuta la instrucción que allí se encuentra.

#### **EJEMPLO**

BNE R2, R3, 100 : Si R2 $\neq$ R3, PC = 100 BNE R5, R7, 64 : Si R5 $\neq$ R7, PC = 64

## LW

## Cargar palabra

#### FORMATO ENSAMBLADOR

LW RT, offset(RS)

## **CODIFICACIÓN**

| 01011 |    |    | RS |    |    | RT |      | OFFSET |   |
|-------|----|----|----|----|----|----|------|--------|---|
| 31    | 27 | 26 |    | 23 | 22 | 19 | 9 18 |        | ( |

### **OPERACIÓN**

if 
$$(bit[31:27] == 01011)$$
  
RT = MEM(RS + offset)

### **DESCRIPCIÓN**

Si el código de operación de la instrucción es el establecido para el LW, toma el valor en memoria que se encuentra en la posición RT sumado con el número inmediato u *offset* y almacena el valor de la palabra encontrada en el registro RS.

#### **EJEMPLO**

LW R2, 100(R3) : R2 = MEM(R3 + 100)

LW R5, 256(R7) : R5 = MEM(R7 + 256)

## LB

## Cargar byte

#### FORMATO ENSAMBLADOR

LB RT, offset(RS)

## **CODIFICACIÓN**



### **OPERACIÓN**

if (bit[31:27] == 01100)RT = MEM(RS + offset[7:0])

## DESCRIPCIÓN

Si el código de operación de la instrucción es el establecido para el LB, toma el valor en memoria que se encuentra en la posición RT sumado con el número inmediato u *offset* y almacena el valor del byte (8 bits) encontrado en el registro RS.

#### **EJEMPLO**

LB R2, 100(R3) :  $R2 = MEM(R3 + 100_{7:0})$ 

LB R5, 256(R7) :  $R5 = MEM(R7 + 256_{7:0})$ 

## SW

## Almacenar palabra

#### FORMATO ENSAMBLADOR

SW RT, offset(RS)

## **CODIFICACIÓN**

| 01101 |    | RS |    | RT | Ť     | OFFSET |  |  |
|-------|----|----|----|----|-------|--------|--|--|
| 31    | 27 | 26 | 23 | 22 | 19 18 |        |  |  |

### **OPERACIÓN**

if 
$$(bit[31:27] == 01101)$$
  
 $MEM(RS + offset) = RT$ 

### **DESCRIPCIÓN**

Si el código de operación de la instrucción es el establecido para el SW, toma el valor del registro RS y lo almacena en la posición de memoria de RT + Inmediato (MEM[Rt+Inm] = Rs).

## **EJEMPLO**

SW R2, 100(R3) : MEM(R3 + 100) = R2

SW R5, 256(R7) : MEM(R7 + 256) = R5

J Salto

#### FORMATO ENSAMBLADOR

J etiqueta

### **CODIFICACIÓN**



## **OPERACIÓN**

### **DESCRIPCIÓN**

Si el código de operación de la instrucción es el establecido para el J, salta a la dirección nueva, calculada mediante el PC y la etiqueta (dirección).

#### **EJEMPLO**

J loop : PC = bit[9:0]loop

J param: PC = bit [9:0]param

#### **NOTA**

Nótese que '*etiqueta*' corresponde a los primeros 27 bits de la instrucción, la cual representa una dirección.

## **5.EXCEPCIONES**

### **NOP**

## No realiza operación alguna

#### FORMATO ENSAMBLADOR

**NOP** 

#### CODIFICACIÓN



#### **OPERACIÓN**

if 
$$(bit[31:27] == 11111)$$
  
PC = PC +1

#### DESCRIPCIÓN

Si el código de operación de la instrucción es el establecido para el NOP, esto quiere decir que en ese ciclo de reloj no va a realizarse ninguna operación con el fin de evitar riesgos en la ejecución de las instrucciones que componen el programa.

#### .

#### **EJEMPLO**

NOP: PC = PC+1

#### **NOTA**

El formato de la instrucción NOP es particular. Se estableció de esta forma con el fin de manejarlo de la manera más flexible posible con respecto al diseño propuesto de la microarquitectura.

## 6. TABLA COMPARATIVA

A continuación, se realiza una breve comparación entre el set de instrucciones MIPS y el de instrucciones propuesto en este documento. Esto debido a que la arquitectura JOF32 está basada en MIPS.

| Set de instrucciones JOF32                                                                                                                                                                            | Set de instrucciones MIPS                                                                                                                                                                                    |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>Se propuso dieciséis<br/>instrucciones ya que era la<br/>cantidad necesaria para la<br/>implementación de los<br/>algoritmos requeridos.</li> </ul>                                          | El set de instrucciones MIPS     cuenta con muchas     instrucciones, las cuales     pueden verse en el manual de     referencia rápida del mismo.                                                           |
| Se incluyó la instrucción load<br>byte ya que permite obtener un<br>byte, y los caracteres están<br>compuestos por un byte, por lo<br>que es fácil obtener un caracter.                               | <ul> <li>Dentro del set MIPS, la<br/>instrucción load byte existe. De<br/>aquí se tomó la idea de<br/>implementarlo, por cuestiones<br/>de facilidad en el manejo de las<br/>palabras en memoria.</li> </ul> |
| Los registros constan de cuatro<br>bits dentro de los formatos I y<br>R, ya que solo se tienen<br>dieciséis de estos.                                                                                 | Los registros en las instrucciones constan de 5 bits, ya que se trabaja con mayor cantidad de registros.                                                                                                     |
| Debido a que los registros cuentan con cuatro bits, el inmediato consta de diecinueve bits, por lo que este puede llegar a tener una magnitud mayor que en un procesador MIPS. Aunque, para este caso | Un número inmediato cuenta<br>con 16 bits, por lo que su<br>capacidad en su magnitud será<br>de máximo esta longitud de<br>bits.                                                                             |

| específico, no se utilizan<br>números inmediatos tan<br>grandes.                                                                                                                                                                                        |                                                                                                                                             |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Los registros constan de cuatro<br>bits, por lo que el área, la<br>potencia y el costo disminuyen,<br>ya que hay menor cantidad de<br>buses de datos.                                                                                                   | Los registros son de 5 bits, por<br>lo que el área, consumo y<br>potencia será mayor que en un<br>procesador JOF32.                         |
| • El código de operación cuenta con cinco bits, por lo que pueden haber hasta treinta y dos (2 <sup>5</sup> ) instrucciones, si así se hubiese requerido. Para este caso en particular, solo son necesarias las instrucciones propuestas en el punto 4. | • El código de operación cuenta con seis bits, por lo que MIPS cuenta aproximadamente con sesenta y cuatro (2 <sup>6</sup> ) instrucciones. |